## 10420 CS410001 - Computer Architecture 2016 Appendix C-2 - Sample Output for Project 2

Please refer to the specified output format to generate your output report. Since we are using a script to automatically check your results, if the format does not match with our golden results, yours will be judged as incorrect and get no points. You are encouraged to double check your results on the open test cases using the released golden simulator.

#### Format of each cycle:

```
cycle n
                    # cycle number in decimal
$00: 0xhhhhhhhh # list of register contents. There is a space between ":" and "0x"
$01: 0xhhhhhhhh # 0xhhhhhhhh is the hexadecimal number of the register
                    # other registers' contents
$31: 0xhhhhhhhh
PC: 0xhhhhhhhh
IF: 0xhhhhhhhh [to be stalled/to be flushed]
                                                   # show the content fetched
ID: instruction<sub>d</sub> [to be stalled/fwd EX-DM rs/t $x] # the decoded instruction name
EX: instruction<sub>e</sub> [fwd EX-DM rs/t $x]
                                                   # the instruction executing at EX
                                   # the instruction executing at DM
DM: instruction<sub>m</sub>
WB: instruction<sub>w</sub>
                                   # the instruction executing at WB
                                   # two empty lines followed here
                                   # you then start recording next cycle after this line
```

#### Notes:

- 1. fwd EX-DM rs/t \$x means "forwarding from EX-DM for rs/t \$x"
- 2. Comments are listed here to help you understand the required format; no comments should be on your output files.
- 3. If both source operands  $(r_s, r_t)$  demand forwarding, then process that of  $r_s$  first.
- 4. Report <u>all occurring hazards</u>, i.e. stall, forwarding and flush, **right after** executing the instructions at each cycle.

The following are 5 examples to help you get familiar with the format specification.

### Example 1:

Suppose that the iimage.bin describes the following code:

lw \$2, 0(\$3) or \$3, \$1, \$4 beq \$2, \$3, branch\_line and \$1, \$1, \$0

We first observe the instructions executed in the pipeline for the first few cycles:

|         | IF  | ID  | EX  | DM  | WB  |                        |
|---------|-----|-----|-----|-----|-----|------------------------|
| cycle 0 | lw  | nop | nop | nop | nop |                        |
| cycle 1 | or  | lw  | nop | nop | nop |                        |
| cycle 2 | beq | or  | lw  | nop | nop |                        |
| cycle 3 | and | beq | or  | lw  | nop | # stall detected!      |
| cycle 4 | and | beq | nop | or  | lw  | # forwarding detected! |

The following is the content of snapshot.rpt after executing the above example. (The content of registers are omitted)

### snapshot.rpt of Example 1:

. . .

cycle 3

.. # content of registers

IF: 0x00200824 to\_be\_stalled

ID: BEQ to\_be\_stalled

EX: OR
DM: LW
WB: NOP

cycle 4

. # content of registers

IF: 0x00200824

ID: BEQ fwd\_EX-DM\_rt\_\$3

EX: NOP DM: OR WB: LW

. . .

#### Example 2:

Suppose that the iimage.bin describes the following code:

lw \$3, 0(\$2) bne \$1, \$3, branch\_code and \$2, \$5, \$0

. .

We first observe the instructions executed in the pipeline for the first few cycles:

|         | IF  | ID  | EX  | DM  | WB  |                   |
|---------|-----|-----|-----|-----|-----|-------------------|
| cycle 0 | lw  | nop | nop | nop | nop |                   |
| cycle 1 | bne | lw  | nop | nop | nop |                   |
| cycle 2 | and | bne | lw  | nop | nop | # stall detected! |
| cycle 3 | and | bne | nop | lw  | nop | # stall detected! |
| cycle 4 | and | bne | nop | nop | lw  |                   |

The following is the content of snapshot.rpt after executing the above example. (The content of registers are omitted)

#### snapshot.rpt of Example 2:

. .

cycle 2

... # content of registers

IF: 0x00A01024 to\_be\_stalled

ID: BNE to\_be\_stalled

EX: LW DM: NOP WB: NOP

cycle 3

.. # content of registers

IF: 0x00A01024 to be stalled

ID: BNE to\_be\_stalled

EX: NOP DM: LW WB: NOP

cycle 4

. # content of registers

IF: 0x00A01024

**ID: BNE** 

Prof. Ren-Song Tsay © National Tsing Hua University

EX: NOP DM: NOP WB: LW

. . .

#### Example 3:

Suppose that the iimage.bin describes the following code:

lw \$3, 0(\$2) or \$1, \$3, \$4 and \$2, \$5, \$0 xor \$7, \$8, \$9

We first observe the instructions executed in the pipeline for the first few cycles:

|         | IF  | ID  | EX  | DM  | WB  |                   |
|---------|-----|-----|-----|-----|-----|-------------------|
| cycle 0 | lw  | nop | nop | nop | nop |                   |
| cycle 1 | or  | lw  | nop | nop | nop |                   |
| cycle 2 | and | or  | lw  | nop | nop | # stall detected! |
| cycle 3 | and | or  | nop | lw  | nop | # stall detected! |
| cycle 4 | and | or  | nop | nop | lw  |                   |

The following is the content of snapshot.rpt after executing the above example. (The content of registers are omitted)

#### snapshot.rpt of Example 3:

...

cycle 2

... # content of registers

IF: 0x00A01024 to\_be\_stalled

ID: OR to be stalled

EX: LW DM: NOP WB: NOP

cycle 3

.. # content of registers

IF: 0x00A01024 to\_be\_stalled

ID: OR to\_be\_stalled

EX: NOP

Prof. Ren-Song Tsay © National Tsing Hua University

DM: LW WB: NOP

cycle 4

.. # content of registers

IF: 0x00A01024

ID: OR
EX: NOP
DM: NOP
WB: LW

. . .